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هذا البحث هو شرح طريقة إستخدام 0۷ں المسؤل عن إنشاء أجهزه ديناميكيه في مجلد ال ۷هل/ 
أهم النقاط اله ستفاده من البحث 

٠‏ التعرف على فلسفة تسميات الأجهزه و تغيرها 

٠‏ طريقة كتابة أسماء جديده للأجهزه و الإحتفاظ بالاأسم الجديد 

٠‏ طريقة كتابة القواعد الخاصة بالأجهزه وسنستعرض بعض من هذه القواعد 

٠‏ تشغيل برامج مجرد إرتباط جهاز خارجي بجهاز الكومبيوتر 

٠‏ تغير الصلاحيات و أسم المالك لاجهاز 

Nerwork Interface dı إعادة تسي‎ ٠» 


1. المقدمة 


كثير من المستخدمين المبتدئين و المحترفين يقعون في فخ أسماء الأجهزه , فالكثير منا يعلم أن ترتيب الأقراص الصلبه ( 
0 ) في نظام تشغيل جنو/لينوكس يأخذ ترتيب أبجدي مثل ال ل ,ع , ظط , همع إسباقها بإاختصار مثل لط او لك 
يعود هذا إلى نوع القرص الصلب ( ١00‏ ) , لكن تخيل معي أكثر مشكله أصادف الكثير من المستخدمين وتكون 
الخسائر بها فادحة و هي , أنه من المعلوم أن القرص الرئيسي هو هلم إفتراضا , فإذا وضعنا قرص أخر خارجي فقد 
أصبح لدينا الأن هل و طك , ثما إذا قمنا بوضع قرص أخر فسيكون الناتج لدينا هر علط , طhd‏ , hda‏ 


ونفترض الأن أننا ريد تهيئة القرص ٥ل‏ ,و الأسرع و الأفضل هو أن نقوم بالتهيئة من الطرفيه , فإذا سهونا عن أننا 
نمتلك ثلاث أقراص وليس قرصين فقد نقوم بتهيئة اك" بدلا من ءل" , تكون المشكله إذا كان طهط يحمل بيانات 
هامه . 


من المشاكل الأخرى التي تسبب ضيق لبعض المستخدمين الجدد والذين يُريدون عمل برامج مثلا للتعامل مع الأجهزه هو 


فرضا أن لديك جهازين يعملان باد 58ل , الأول للكميره رقميه ه۲٥"‏ ه٥‏ اهاأوا و الثاني عباره عن ھا۴ 
(is)‏ , وعادتا ما يتم تعريف الإثنين في مجلد ۷٥ل‏ كتالي 
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بحث تعليمي 


/dev/sdb‏ و ev/sdcل/‏ , لكن السؤال الأن أي منهم الكميره و أي منم أ Flash Disk‏ ؟ 


والأفضل أن نقوم بعمل تسميات كتالي حتى نتجنب الحيره في هذا الأمر /Idev/flashdisk s /dev/camera,‏ . 


ولكن ما يجب معرفته أن كتابة القواعد ليسة سهله ومختصر ه مثل المشاكل التي تحدث عند عدم وجود ٥ل۸0 devi‏ 
لجهاز موجود بالفعل و مركب عندك . 


فالأمر يختلف تماما , فكل مهمة ال ۷هل هي إنشاء مله" هء ۷ه بأسم إفتراضي بإذن من النواه . 
و الإحتفاظ بأسم دائم لل مله" هع ۷ه له العديد من الفوائد كما ذكرنا . 


1 لا كيف نكت القواعد ؟ 
قبل كل شيء يجب أن نفهم الأساسيات 


1- التخطيط لعمل أسم دائم للأجهزه 
بإمكانك إستخدام الأسماء الإفتراضيه التي يقوم 46۷ل بتزويد المستخدم بها , و تكون حل جيد للمستخدم , و 


الأكثر من هذا أنه لا داعي لكتابة قواعد 


فال ۷٥ل‏ يقوم بإنشاء أسماء إفتراضيه للأقراص الصلبه , وتكون موجوده في )ءأل/6۷ , و لمعرفة 
تفاصيل عن هذه الأسماء بإمكانك كتابة الأمر التالي في الطرفيه 
1s -R1 /dev/disk‏ 


فهذه كل أسماء الأقراص التي تعمل الأن على جهازك , فعلى سبيل المثال نجد أن 6۷ں على جهازي قد قام 
بإنشاء 


dev/disk/by-id/ata-Hitachi_HTS541612J9SA00_SBZ2DO2E4K1PKNH 


فهذه الأسم الحقيقي للقرص الرئيسي هل , إذا هو عباره عن وصلة أا عامط" إلى ملف /۷عل/ 
بأسم هو , بينما عندما قمنا بوضع ال ءا ها۴ , فستكون النتيجه هي كتالي . 


dev/disk/by-id/usb-WD_3200BMV_External 57442D575848583038343535353139-0:0 


وهذا أيضا الأسم الحقيقي لل Disk)‏ ashا۴‏ و لھا Symbolic Link‏ إلى مجلد ev‏ بأسم Sd‏ . 
وسنفهم ماذا نقصد بكلمة الأسم الحقيقي ولكن في مرحله متقدمه من هذا البحث . 


2.- الملفات الخاصة بالقواعد و طريقة الصياغة 
هناك بعض الأسئلة التي ستقودنا إجابتها إلى كشف الكتير من فوائد ال ۷هل ں مثل 


- أين ثكتب القواعد ؟ 


۷ل u‏ یقوم بتنفیذ سلسله من القواعد توجد في 5.dعاں ۵٥۷/٣‏ ں/٥۵/‏ , وتکون جمیعھم بإمتداد sعاں٣.‏ 


- أين توجد القواعد الإفتراضيه ؟ 

توجد في المجلد السابق ذكره في السؤال السابق بأسم وه اں٣.6۷ں‏ غالبا برقم 50 , ويُستحسن إلقاء نظره 
على هذا الملف , فهو يحتوي على بعض الأمتله و القواعد التي تعمل , لكن ينبغي الحذر من عدم التعديل على 
هذا الملف بصوره مباشره , فله طريقة للتعديل سيتم ذكرها لاحقاً . 


الملفات في 85.0|ل٣‏ مرتبه ترتيب مرقم وفي بعض الحالات يكون الترتيب على حسب الأهميه , ولكن اذا 
کنت رید أن تكتب قواعدك الشخصيه فمن المستحسن ترقيمه بأقل رقم أي إذا كان أصغر رقم في هذا المجلد 
رقم 20 فإجعل ملف قواعدك رقم 19 وهكذا . 


- هل هناك علامه للتعليقات ؟ 
نعم - فتعتبر علامة # تعليق , خلاف هذا فهي قاعدة . 


ES 
. أهم شيء هو عدم كتابة القاعده ف في آکٿر من سطر , بل یجب کتابتها عى سطر واحد‎ - 


- هل من الممكن أن يتطابق الجهاز الواحد مع أكثر من قاعده ؟ 

نعم - وهذه تعتبر ميزه عمليه في ال ۷هل , فبإمكانك كتابة قاعدتين للتوافق مع جهاز واحد , حيث أن 
كل قاعده تعطي الأسم البديل للجهاز فكل من الإسمين سيتم إنشائهم , حتى إذا كان ملف القاعده الأولى منفصل 
عن ملف القاعده التثانيه , فمن الضروري فهم أنه لم يتوقف ال ۷٥ل‏ عن مُعالجة و تنفيذ القواعد مادامت 
متوافقه مع الجهاز , بل سيقوم أيضا بالبحث و المحاوله لقبول كل القواعد التي يُصادفها أمامه . 


أساسبات كتابة القو اعد 


القواعد بصورہ عامھ عبارہ عن مجموعة مفاتیح کون ملف یُسمی ملف sھاںم‏ , وتتکون ال sھاںم‏ من زوجین من 


تيح الهامه فصل بينهم ڊ ( , ) وتكون الصيغه بهذا الشكل key , value‏ 


هذه المفاتيح الأولى natch-key li‏ و lllنيa Assignment-key Jai‏ . 
ال y¥ke-matchص‏ هي عباره عن مُعرفات ثابته ( رهلا ) وهي من سيطبق عليها الشروط , فهي تقوم بتحديد أي 
الأاجهزه التي سينطبق عليها القواعد ( وئعاںا ). 


المثال التالي يُوضح الطريقة الأساسيه لكتابة وعاںم 
KERNEL==”hdb” , NAME=”My-Hard-Disk”‏ 


lلكأnlة Assignment-Key حlتnll Jinî NAME ةãnlئ liıڊ , Mach-Key حlتnll Jai KERNEL‏ , 
ولأسماء هذا المفاتيح قواعد وكلمات محددة سنتحدث عنها لاحقاً في هذا البحث . 


هم شيءِ يجب ملاحظتة هو أن أ Match-Key‏ يأتي بعده علامة المساواه مزدوجة ( == ) دائماً , بينما ال 
Assignment-Key‏ يأتي بعده علامة مساواه واحده ( = ) , وما یجب معرفته أيضا أن ال UV‏ لا تدعم ال ٥6ا‏ 
Continuation‏ أي تقبل مسافة واحده فقط بيضاء ولا يجوز إستخدام مسافات مثل ال ط4٣‏ إلى في حالات محدوده , 
أیضا لا ٹکتب ال sھاںم‏ الواحده على سطرین( أي بالضغط علی زر ٤6١‏ ) , فسیعتبرھا 6۷ں قاعدتین وھذا من 
المّأكد أنه سيأدي إلى نتائج غير مرغوب بها . 


أساسبات القو اعد 


يقوم 46۷ل بتزويدنا بالعديد من ال رم ءج الجاهزه للإستخدام لكتابة القواعد التي تطابق الأجهزة بدقة شديدة , 
و ر آخرين في وقت لاحق في هذه الوثيقة للحصول على 
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مفتاح 1ج1 تستخدم للأجهزه التي عرف من خلال النواه KERNEL‏ 
مفتاح ٥ج‏ تستخدم لأجهزة النظم الفرعيه SUBSYSTEM‏ 
مفتاح 1٥ج‏ يستخدم لأسم الجهاز الذي يُمنح للجهاز نفسه DRIVER‏ 


نأتي بعد ذالك إلى مفاتيح إ۴6-أ ۸٠٣٠/١‏ واوو حيث آنها تقدم المزيد من التحكم و المزيد من السيطره على جميع 
الأجهزه , والجدير بالذكر أن هناك العديد من أنواع هذه المفاتيح , ولكننا سنستعرض أهمها و التي تستخدم بكثره . 


الأسم الذي ستقوم بإستخدامة  NAME Device Node‏ 
إختصار يكون بديل أخر لأا« SYMLINK Device Node JI‏ 


الملاحظة التي يجب عليك الإنتباه لها هي , أن ۷٥ں‏ يقوم بإنشاء مله" هءأ۷هل واحد لجهاز واحد , أي لا يقوم 
بانشاء العدید منj‏ | Device Node‏ ليا واحد , وإذا كنت ثريد إنشاء أسماء أخرى Devicé Node‏ , فستقوم 
بإستخدام الوظيفة )ال8 , ففي الحقيقه كل ما ستفعله هو طلب إختصار للجهاز المطلوب تغير أسمه , أي أن 

كل الأسماء ستقودك إلى الجهاز المحدد . ولكي تقوم بتعديل القائمة سنحتاج إلى إضافة مُعامل بعد SYMLÎNK inl‏ 
وهو =+ , كما أنه بإمكانك إلحاق أي عدد من ال )اال في ملف ال عا مع الفصل بينهم بمسافه واحده بيضاء . 


KERNEL==“hdb” , NAME=“My Spare _ Disk” 


القاعده السابقه تقول : الجهاز الأتي من النواه والذي يتمثل في المفتاح عاج و الذي أسمه طك۸ , سيكون أسمه الجديد 
My_Spare_Disk‏ و سيظر >ۃJlaي /dev/My_Spare_Disk‏ . 


KERNEL==“hdb” , DRIVER==”ide-disk” , SYMLINK+=”spare disk” 


القاعده السابقه تقول : الجهاز الأآتي من النواه و الذي يتمثل في مفتاح عاج" و الذي أسمه طلم الذي أسمه المُعلن 
)sل-هلi‏ , سيكون أسمه الإفتراضي الذي سيصبح عليه و الذي سيتم إنشاء وصله له بأسم )ءأل_6 2م . 
الملاحظة هنا أننا لم نحدد أَسم device node d‏ , لذالك فسيقوم 6۷ں بإستخدام الأسم الإفتراضي , من أجل الحفاظ 
على تخطیط مجلد ۷/ , فالقاعده الخاصه بك سیکون إذنھا على ال NA M۴٤‏ فقط , لکن إنشاء )٣ا6‏ او أدي 
واجبات اخری . 


KERNEL ==“ hdc”, SYMLINK +=*cdrom cdromO0” 


القاعده السابقه قد تكون أكثر القواعد نموذجيه عن سابقها من القواعد , فقد تم إنشاء إختصlرjı Symbolic Link‏ 
بأسماء /dev/cd r0‏ و r00‏ ev/cdل/‏ وکلیهما لهم نقطه واحد و ev/hdل/‏ , ولم نستخدم الخاصیه NAME‏ 
لأن الأسم الإفتراضي التي تستخدمه النواه هر عل . 


ملامة صفات ءfور؟‏ 


حتى الأن ال ره ءج" التي قمنا بتقديمها تقوم بقدرات محدوده جدا , والمطلوب أن نقوم بعمل سيطره أكثر من هذا , 
فنحن نريد تحديد الأجهزة على أساس الخصائص المتقدمة مثلا على أساس نظام لمجموعة قواعد و قوانين أو رقم المنتج 
أو الرقم المسلسل أو سعة التخزين للجهاز أو رقم القسم في القرص الصلب .. إلخ . 


بعض الأجهز ه تقوم بتصدير متل هذه المعلومات إلى 5أكل؟ , و 06۷ل يسمح لنا بدمج هذه المعلومات و توفيق 
العمليات في القاعده ومام , عن طريق إستخدام المفتاح ۸۲۲۴ مع قليل من الإختلاف في صياغة القاعده مالآ . 
الأن لينا قاعده الحكم الذي سيننذ فيها على أساس من معلومات من 5أكرة ا ف ر و 
کتابه قواعد مبنیه على ال sگئل؟‏ . 

SUBSYSTEM==/pþlock” , ATTR{size}==72234343824334” , SYMLINK+=my_ disk” 


النظام الهرمي للأجهز ٥‏ 


في نواة لينكس ثمتل الأجهزه في بنيه شبيه بالشجره , ومعلومات هذه الأجهزه ثكشف عن طريق f5ءلء‏ حيث أنها تكون 
مفيده عند كتابتنا للقواعد , فعلى سبيل المثال , قرصي الصلب هو أبن لفرع معءأاه0 )ا |55 ,الذي هو فرع من 
اجھزۃ ۸۲۸ , و الذي هو فرع من أجهزة ال وط ۴٣|‏ ( يُمكنك مُراجهة المخرجات التي في أول البحث ) , و من المحتمل أن 
تجد نفسك بحاجة إلى معلومات من أحد الفروع عن طريق تقديم إستعلام أو سؤال فت لا گنت ارید ارق اسل 
للقرص الصلب , فبكل بساطه سنقوم بسؤال الفرع الأكبر منه أو الأب للقرص الصلب الذي هر )وأ إ؟S٥S‏ . 


وهناك مفاتيح إه)-عأهم هام لدينا وسيّضاف إلى المجموعه السابق ذكرها وهي (۸۲۲۸) , قیم ال رھ)-ac۸۾"‏ 
د فقط للأجهزه ولكن لا تصلح للفرو ع الأساسيه , ولكن 6۷ں يقدم متغير ات لد ره)-۸عأهم" ثتمكنه من البحث و 
التنقيم في المستويات العليا أو الفروع العليا للجهاز . 


وبهذا سنقوم بإعادت شرح جميع ال إه-۸ ٥ه(‏ السابقه في حالة الإستعلام . 


الأسم الممنوح من النواه للجهاز , أو الأسم الممنوح من النوه للفرع KERNEL‏ 
النظام الفرعي للجهاز , أو الأسم الفرعي لأي فرع للأي جهاز SUBSYSTEM‏ 
أسم التعريف الذي يدل على الجهاز , أسم التعريف الذي يدل على أي فرع لجهاز DRIVER‏ 
صفة ورو للجهاز , أو صفة fsورء‏ لأي فرع لجهاز ATTR‏ 


أعتقد بعدما إتض تضحة فكر ه النظام الهرمي للأجهزه أن كتابة القواعد الأن ستكون أقل تعقيدا من السابق , ولا داعي للقلق 
حيث أن هناك أدوات تقوم بمساعدتك , وسيتم عرضها عليك في مرحلة متقدمه من هذه الوثيقه . 


سلسلة الإستبدالات 
String substitutions‏ 


عند كتابة القواعد التي من المحتمل تعاملها مع العديد من الأجهزه , فيكون من المستحسن إستخدام صيغ مُختصره 
مفهومه ل ۷٥ں‏ , وأشهر إختصارين يُمكن الإستفاده منهم في هذه الحاله هم الإختصارين )% و %۸ . 


)% : تعبر عن أسم الجهاز داخل النواه , مثل "1هلء" ويكون المكان الإفتراضي له هو 021ء/6۷ل/ . 
٠‏ : تعبر عن رقم الجهاز في النواه أو رقم القسم للقرص الصلب , فمثلاً رقم 1 ل a1لء‏ وهكذا . 


ولفهم طريقة إستخدام أسلوب ء٣‏ 0اا Subs)‏ وStrin‏ تابع المتال التالي 


x 


HRNEL==“mice”, NAME=”input/%k” 
KERNEL==” l]oop0”, NAME=”loop/$%n”, SYMLINK+=*%k” 


أول قاعده تقول : إنقل الجهاز الموجود في النواه بأسم هعم إلى المجلد التالي /ألام| حتي يكون كتالي 
/dev/input/mice‏ 


أما القاعده الثانيه تقول : إنقل الجهاز |٠٠0‏ الذي في النواه إلى مجلد |٥٥/‏ حتي يكون المسار الخاص به كتالي 
0هل / و قم بإنشاء إختصار له دائم في المجلد الرئيسي حتي يكون بهذا الشكل 0مهه|ا/۷هل/ . 


لکن في هذه القاعدتين السابقتين شك , لأنها کلھا یمکن أن تعاد صیاغتها دون استخدام أسلوب String‏ 
Substitutions‏ , لکن فائدتها الجو هريه ستتضح في الجزء التالي . 


String Matching 


عندما يتأكد ۷عهں من كتابة ال و١ S٣‏ و١‏ ااج بأسلوب صحيح , فسيسمح لك بإستخدام بعض العلامات ( شبيه 
بعملیات ا56 ) , و هم ثلاث علامات كتالي : 
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2 : تعني تذ تخمين حرف واحد فقط 
[] : تعني تخمين أي حرف أو رقم من داخل مجال القوسين 


_ تلم كتابة قواعد العا 


المتال التالي يوضح كيفية إستخدام هذه العلامات مع الجjء‏ اlulبJق String Substitutions‏ . 


KERNEL==”fd [0-9]*”, NAME=”floppy/%n”, SYMLINK+=” $k” 
KERNEL==”hiddev*”, NAME=”usb/%k” 


في القاعده الأول نقول فيها : إبحث عن كل أجهزة ال الك رممه|؟ و الذي ستعثر عليه قم بإضافته في مجلد إممها 
لكي يكون المسار كتالي ۷/0 ممه|؟/۷٠هل/‏ و قم بإنشاء إختصار له في المجلد الرئيسي لكي يكون كتالي 0؟/۷هل/ 
( بأسم الجهاز الصادر من النوه كما هو ) . 


و ثلاحظ أن في المفتاح الأول قمنا بتحديد مدى الأرقام التي سيبحث فيها وهي من 0 إلى 9 و قمنا بإحاطتهم بالقوسين 
المربعين [ ] , وألحقناها بالنجمه التي تعني أي شيء بعده إذا وأجد ذالك . 


في القاعده الثانيه نقول فيها : إييبحث عن أي جهاز يبدء ب 6۷ل لام و قم بإضافته في مجلد طاول حتي يكون مساره 
كتالي v4392صdev/usb/hidde/‏ . 
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الع 1 مات من ءfو‏ 
شجرة fsورS‏ 


فكرة الإعتماد على معلومات من ءاولو فکره رائعه و ممتعه جداً , و بالطبع لفهم هذه الفكره بصوره واعيه , يجب عليك أنت 
تکون قد استوعبت ما ذکرناه سابقاً , وللبدء في كتابة وم انم مُعتمده على المعلومات ا ف م اکت ای 
الف المكارله ليا 


65 في الواقع له بُنيه شديدة البساطه , فهو ينقسم بصوره منطقيه إلى مجموعة دلائل , كل دليل يحتوي على رقم u ts‏ ط|ًat‏ 
أي يحتوي على قيمه واحده فقط , وهناك بعض الإختصارات موجوده , التي تتصل بالفرع الرئيسي لها ( ستفهم معناها فيما بعد ) و الذي 
اکل المرمی کا در كا 


بعض هذه الأدله الموجوده يشار بها ب ۸ةم عامل امها-مهt‏ , هذا الأدله تماما مثل الأجهزه الحقيقيه ولها أيضا ععأاهل 
م" تتعامل معه , وهي تصنف في دليل ال ءfولء‏ بان لها أجهزه في المجلد ۷ه , و الدليل على هذا الأمر التالي 
find /sys -name dev‏ 


على سبيل المثال : لدي على جهاز ي المسار التالي هلء/)عهاط/ورء/ وهو مسار القرص الصلب لدي و يُسمى ( ععأاهل 
path‏ ) , وهو متصل بالفرع الرئيسي له وهو eعأ۷اهل‏ )أك |ا؟٥S‏ , وبإمكانك مشاهده هذا عن طريق وجود إختصار بأسم 
device‏ , أي المسار كتالي 

/sys/block/sda/device 
. ستكتشف أنه الفرع الرئيسي لقرصي الصلب‎ 


وعندما تحب أن تكتب قاعدة مبنيه على معلومات من ءfءلء‏ , فبكل سهوله ستضع الصفه التي ثريد من أي جزء من صفات 
جهازك . 
س , بإمكاني إستخدام مساحة قرصي الصلب كصفة , وبإمكاني معرفت ذالك عن طريق التالي 
cat /sys/block/sda/size‏ 
234441648 


عند إستخدام هذه المعلومه كمعرف للقرص الصلب ول ء مع قواعد ال رعلں ستكون كتالي . 

ATTR{size}==”234441648” 
عندها سيقوم لن بالكشف عن هذه السعه في كل الأجهزه الموجوده عنده ( أقصد الأقراص الصلبه ) , و من الأفضل إختيار‎ 
صفات أخرى إذا أمكن هذا فمتلا بإمكانك التجول في ء1 عل /هل5/)-٥10ط/5رء/و معرفة محتويات الملفات الموجوده‎ 
وهذا بالطبع عن طريق الأمر جع كما شرحنا في المثال السابق , وجميعهم سيكون معرفهم في ملف القواد ب ۸۲۲۸ كما شرحنا‎ 
. كما أن هناك سلسله ملفات ( أو مجموعة ملفات ) يجب الحذر في التعامل معها وسوف نستعرضها فيما بعد‎ 


وعلى الرغم من أن هذه مقدمه رائعه لمعرفة كيفية الحصول على معلومات من ء٤‏ ءرء و أيضا معرفة الهيكل الخاص به و 
طريقة تعاملنا معه من خلال ال علن , إلى أن كل هذا مضيعه للوقت فإذا زاد العمل زاد معها العناء . 


Udevinfo OR udevadm 


هذه البرامج سهله جدا و بسيطه تساعدك على كتابه القاعده الخاصه بك بصوره إحترافيه , وكل ما تحتاج إليه هو معرفة مسار 
جهازك داخل بُنية ورو ( أي داخل مجلد وء روء ) و شاهد المثال التالي : 
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# udevadm info -a -p /sys/block/sda 


Udevadm info starts with the device specified by the devpath and then 
walks up the chain of parent devices. It prints for every device 
found, all possible attributes in the udev rules key format. 

A rule to match, can be composed by the attributes of the device 

and the attributes from one single parent device. 


looking at device '/block/sda' : 

KERNEL==" sda" 
SUBSYSTEM=="block" 
DRIVER=="" 
ATTR{range}=="16" 
ATTR{ext_range}=="256" 
ATTR{removable}=="0" 
ATTR{ro}=="0" 
ATTR{size}=="234441648" 
ATTR{capability}=="52" 
ATTR{stat}==" 77280 5163 3 667503 477134 125055 1382528 

629930 0 392870 1297360" 


looking at parent device 
'/devices/pci0000:00/0000:00:1f£.2/host2/target2:0:0/2:0:0:0': 

KERNELS=="2:0:0:0" 
SUBSYSTEMS=="scsi" 
DRIVERS=="sd" 
ATTRS{device_blocked}=="0" 
ATTRS{ type}=="0" 
ATTRS{scsi_level}=="6" 
ATTRS{vendor}=="ATA 8 
ATTRS{model}=="Hitachi HTS54161" 
ATTRS {rev}==" SBDO" 
ATTRS{state}=="running" 
ATTRS{ timeout}==" 30" 
ATTRS{iocounterbits}==" 32" 
ATTRS{iorequest_cnt}=="(xle86e" 
ATTRS{iodone_cnt}=="(xl1e86e" 
ATTRS{ioerr_cnt}=="0x1" 
ATTRS{modalias}=="scsi: t-0x00" 
ATTRS{evt_media_change}=="0" 
ATTRS {queue_depth}=="31" 
ATTRS {queue_type}=="simple" 


looking at parent device '/devices/pci0000:00/0000:00:1f.2/host2/target2:0:0': 
KERNELS=="target2: 0:0" 
SUBSYSTEMS=="" 
DRIVERS=="" 


looking at parent device '/devices/pci0000:00/0000:00:1f.2/host2': 
KERNELS=="host2" 
SUBSYSTEMS=="" 
DRIVERS=="" 


looking at parent device '/devices/pci0000:00/0000:00:1f.2': 
KERNELS=="0000:00:1f£.2" 
SUBSYSTEMS=="pci" 


صفحة 11 


DRIVERS=="ahci" 
ATTRS{vendor}=="0x8086" 

ATTRS {device}=="0x27c5" 
ATTRS{subsystem_ vendor}=="0x1558" 
ATTRS{subsystem device}=="0x0660" 
ATTRS{class}=="0x010601" 
ATTRS{irq}=="28" 
ATTRS{local_cpus}=="ff" 
ATTRS{local_cpulist}=="0-7" 
ATTRS{modalias}=="pci:v00008086d000027C5sv00001558sd00000660bc01sc06i01" 
ATTRS{enable}=="1" 

ATTRS{broken_ parity_status}=="0" 
ATTIRS {msi_bus}=="" 


looking at parent device '/devices/pci0000:00': 
KERNELS=="pci10000: 00" 


SUBSYSTEMS=="" 
DRIVERS=="" 


# udevinfo -a -p /sys/block/sda 


looking at device '/block/sda': 


KERNEL=="sda" 

SUBSYSTEM==" block" 

ATTIR{stat}==" 12855 2246 2788977 766188 73998 31/300 6 
57354 9 516516 650106 


ATTR{size}=="234441648" 
ATTR{removable}=="0" 
ATTR{range}=="16" 
ATTR{dev}=="8:0" 


looking at parent device 

'/devices/pci0000:00/0000:00:07.0/host0/targetO0:0:0/0:0:0:0': 
KERNELS=="0:0:0:0" 
SUBSYSTEMS=="scsi" 
DRIVERS=="sd" 
ATTRS{ioerr_cnt}=="0x0" 
ATTRS{iodone_cnt}=="0x31737" 
ATTRS{iorequest_cnt}=="0x31737" 
ATTRS{iocounterbits}=="32" 
ATTRS{timeout}=="30" 
ATTRS{state}=="running" 
ATTRS{rev}=="3.42" 
ATTRS{model}=="ST3120827AS9" 
ATTRS{vendor}=="ATA" 
ATTRS{scsi level}=="6" 
ATTRS{type}=="0" 
ATTRS{queue type}=="none" 
ATTRS{queue_ depth}=="1" 
ATTRS{device_ blocked}=="0" 


looking at parent device '/devices/pci0000:00/0000:00:07.0': 


KERNELS=="0000:00:07.0" 
SUBSYSTEMS==" pci" 


صفحة 12 


* 


کتایة فواعد ائے ع0 
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__ طم كتابة قواعد الےرع لا 


DRIVERS=="sata_nv" 
ATTRS{vendor}=="0x10de" 
ATTRS{device}=="0x037f" 


كما رأيتم فكل من البرنامجين يقدم مجمو عه من ال رءk-1طء‏ هم و ال رعk-وءاuط1إج‏ خم التي بإمكانك إستخدامها في 

ملف القواعد الخاص بك , فبإمكانى الإستفاده من المعلومات السابقه كتالى مثلا 
SUBSYSTEM=="plock", ATTR{(size}=="234441648", NAME="my hard disk"‏ 
SUBSYSTEM=="block", SUBSYSTEMS=="scsi", ATTRS {model}=="ST3120827AS",‏ 
NAME="my hard disk"‏ 


المكتوب باللون الأزرق , هو حصر للقرص الصلب ( على إعتبار أن هناك أكثر من قرص واحد ) , وأيضا لمعرفة انه من الوارد 
إستخدام آکثر من معلومه في القاعده الواحده ولکن لیس من القانوني أن تقوم بالمز ج بين ال attributes-key‏ في 
الأجزاء الرئيسيه , أنظر المتل التالي لكي تفهم ما أقصده جيداً و بعد ذالك قارن المثال التالي بالمتال السابق و لاحظ مخرجات 
البرنا 


SUBSYSTEM=="plock";, ATIRS{MOMe1L J =ESTI12092 7A5", DRIVERS=Esata nv", 
NAME="my hard disk" 
هكذا لن تعمل هذه القاعدة و سيتم رفضها من عدن , وعلى أي حال , يقوم البرنامج بتزويدك بعدد ضخم من ال‎ 
وبإمكانك إختيار أي عدد منهم لتركيب قاعدتك دون اللجوء إلى التشتت بين الفروع الرئيسيه , ويجب‎ tt rib ut es-key 
يدل غلئ الجهاز بصفه دائمه ) اي لا تختار الأصفار 0 ( أي أنني عندما أخترت في‎ attributes-key أيضاً أن تختار‎ 
المتال الأول وء ٤ں ط ذإ خخج كان يدل على مساحة القرص , ولم استخدم أرقام غامضة متل‎ 
ATTR{iodone_ cnt}=*70x2324} 
لاحظ تدر ج المُخرجات في برنامج صله ٠هن أو ٥٣ذ علن , في اللون الأزرق , يُمكن عمل إستعلام أي بإستخدام ال‎ 
.KERNEL , ATTR Jîn Match-key 
في الون الأخضر الأحمر الداكن نستعلم من خلال الفروع الرئيسيه عن طريق ال رهk)-وه†uطذإخ خم مثل‎ 
. SUBSYSTEMS, ATTR 


قد يكون هناك سؤال الأن يدور في عقلك وهو , كيف أحدد الجهاز المطلوب في مجلد وري ؟ 


بإمكانك تحديد لأحد البرنامجين المسار المطلوب للجهاز إذا كنت تعرفه أو تدعه هو الذي ييحث لك عنه , وهذا عن طريق المتال 
التالى 


udevadm info -a -p $ (udevadm info -q path -n /dev/sda) 


udevinfo -a -p $(udevinfo -q path -n /dev/sda) 


ق البديله 


[3 


= 


على الرغم من أن صله 7هن أر ٥٤ذ‏ ههن يقدمان أسلوب بسيط للحصول على المعلومات الخاصه بالجهاز و التي 
تساعدك في كتابة قواعدك , إلى أن هناك برامج أفضل منها مثل س٠‏ ذ7 طون والتي تقوم أيضا بإظهار الكثير من المعلومات . 


ownership ) GlaSÛhll yg ( Permissions التحكم فى الترخ‎ 


يسمح لك 7ء لن بإضافة ره »- ا عص دن ووه أخرى تقوم بدورها بالتحكم في التراخيص و الملكيات على كل الأجهزه . 
فالمفتاح ۸00 يسمح لك أن تحدد أي مجمو عه ينتمي إليها ملم" هء> ءل ما في القاعد , و المثال التالي يوضح كيف 
سنقوم بمنح جھاز f٥٣‏ عص fra‏ إلى مجمو عة ال معمd ۷V1‏ 


KERNEL==” fb [0-9]*”, NAME=“fd$n”, SYMLINK+=*%k” , GROUP=* video” 


المفتاح N٤۴‏ 0۷ ربما يكون أقل فائده ولكنه يسمح بأن تقوم بتحديد أي مستخدم هو الذي له السلطه و الصلاحيه على معام 
"م ما , على إفتراض أن هذا الجهاز حاله إستثنائيه أو حكر على مستخدم مُعين , فمثلا إذا كنت أريد أن أجعل قرصي 
الخارجي حكر على المستخدم ه22ط۸ فقط فسيكون كتالي 


KERNEL==”sdb [0-9] **, OWNER=”Abaza” 


۷لا يقوم إفتراضيا عند إنشاء أي جهاز بمنح ترخيص 0660 ( قراءه و كتابه ) للمستخدم و مجموعته , فمثلا إذا أردنا تغير 
ترخیص لجهاز ما , ولنفترض أنه جهاز الاقراص المرنه ( )یا ۷م مہا۴ ) , فسنستخدم المفتاح ٧09٤‏ لهذا الغرض كما 
بالمثال التالي 


KERNEL==”fd[0-9]**”, NAME=“floppy/%n”, SYMLINK+=*%k” , MODE=”0666” 


تم هكذا إعطاء تصريح للقراء و الكتابه للجميع ( غير مستحسن عمل هذا عشوائيا إلى إذا كنت تعرف ما تفعل ). 


أستخدام برنامج خارجى لتسمية الأجهزه 


في بعض الأحيان قد نحتاج إلى برنامج يقوم هو بإختيار أسماء للأجهزه و غير المألوفه بالنسبه للنواه و ۷هلں , ولكن ۷علں 
يُقدم إمكانيه لطلب تشغيل برنامج عند العثور على جهاز مُعين , و إعطائه الأسم الأصلي لكي يقوم البرنامج بإخراج الأسم الجديد. 


ولإستخدام هذه الطريقه , أولا نحتاج إلى وجود برنامج يهتم بهذا ( أي أنه من صنعك متلا ) , و سأفترض أن هناك برنامج يقوم 
بهذه المهمه و مکانه في 1۸ط/اھCc٥|/٣sں/‏ و أسمه 2۳6۴ "_۷عل_nء‏ , بإستخدام مفتاح RAN‏ ۴۸06 في القاعده و إعطائه 
الأسم المطلوب تغيره , لكي يقوم البرنامج بإعطاء الناتج في المتغير %٥‏ و الذي يُمكن إستخدامه مع المفتاحين , NAME‏ 

ML NK‏ , ستکون القاعده کتالي 


KERNEL==/hda”, PROGRAM=”/usr/local/bin/ch dev name $k”, SYMLINK+=”%c” 


المثال السابق قام البرنامج بأخذ بارميتر صادر من النواه و الذي يُمتل أسم الجهاز في النواه , و بناء على هذا سيقوم 
v_nameهd_مه‏ بإنتاج أسم جديد كمخر ج عادي ااه لاء , ينقسم إلى عدة أجزاء , كل جزء عباره عن كلمه واحده يُفصل 
بينهما بمسافه ( مثل المصفوفات في البرمجه ). 


و أفترضنا أن البرنامج أخرج أرقام الأجزاء التي قمنا بإعطائها للمفتاح )|6۲1 لإنشائها بدلا من الأسماء. 
في المثال التالي سنفترض أن البرنامج ۳٠‏ ۷_"2هل_"١ء‏ أخرج جزئين , الأول لأسم الجهاز و الثاني لأسم الإختصار , في هذا 


الحاله سنقوم بإستخدام العلامه السابقه مع القليل من الإضافات كي تكون بهذا الشكل إ0%)N‏ حيث أن ل١‏ هو رقم الجزء , وتكون 
القاعده کتالي 


KERNEL==/hda”, PROGRAM=”/usr/local/bin/ch dev name $k”, NAME=”%c{1}” , 
SYMLINL+=%c{2}” 


نفترض أن البرنامج يقوم بإخراج أكثر من جزء , لحل هذا سيكون العلامه بهذا الشكل [+١)%ء‏ حيث أن + هي الجزء 
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المطلوب و تكون ترتيبها كتالي ٥أع..,2+1,N+N N,‏ لأخر المخرجات , تابع التعديل على المتل السابق. 
KERNEL==/hda”, PROGRAM=”/usr/local/bin/ch dev name $k”, NAME=”%c{1}” ,‏ 
SYMLINL+=%$c{2+}”‏ 


من الممكن إستخدام هذه الطريقه مع مفاتيح أآخرى ليس فقط مع NAM٤‏ و SYMLINK‏ , تابع هذا المثال و نحن نقوم بجعل 
برنامج لنا يقوم بإعطاء التصريح للمجموعه التي يرى البرنامج أنها مُناسبه له . 


KERNEL==“hda”, PROGRAM=”/usr/local/bin/chdevgroup $k” , GROUP=”%c 


تشه نا حدث مع“ 


هناك دافع أخرى لكتابة قواعد د تمكننا من تشغيل برنامج في حالة إتصال جهاز مُعين و فصله , فمثلاً تخيل أنك ثريد أن تكتب 
برنامج يقوم بتحميل كل الصور في مجلد معين عندما تقوم بتوصيل الكميرا الديجيتل أو الهاتف الخلوي . 


قد يأتي في مُخيلتك أن المفتاح ۴۸06۸۸١۷‏ الذي تحدثنا عنه منذ قليل يفي بالغرض , ولكن الإجابه بلا , لأن وظيفة المفتاح 
۴R06R ۷‏ هي إنشاء برنامج لأسماء للأجهزه فقط لا غير , لأن هذا المفتاح يقوم بتنفيذ البرنامج قبل أن يتم إنشاء الجهاز , 
لذالك فهذا المفتاح لا يجوز إستخدامه في فكرتنا . 


وظيفة المفتاح الذي سنتحدث عنه الأن تسمح لك بتنفيذ البرنامج المحدد بعد إنشاء الجهاز و وضعه في مكانه , فهذا البرنامج سيعمل 
على الجهاز المحدد له , ولكن يجب أن تعلم أمر هام وهو أنه يجب أن تجعل البرنامج يتوقف بعد إتمام عمله , كما أنه يجب أن 
تجعل البرنامج يتأكد من أن الملفات تتطابق أم لا حتى نتجنب بعض الأخطأً التي من الوارد الوقوع بها . 


المثال التالي يُوضح كيفية إستخدام المفتاح الذي يقوم بهذا العمل و هو المفتاح الا . 


KERNEL==“sdb” , RUN+=* PROGRAM PATH” 


حيث أنك ستستبدل كلمة _°٥۴۸1۲‏ ۴۸06۸0 بمسار البرنامج الخاص بك , فعند العمل سيكون هناك متغيرات من بيئة 6۷ں 
متوفره في بيئة المتغيرات الخاصه بالنظام , بما في ذالك قيم لمفاتيح مثل 8085۷97۷ , ويُمكنك الإستفاده منها عن طريق 
المفتاح ۸٥۲|0١‏ لإكتشاف أي الأجهزه المتصله و الغير متصله , أي ستحتوي إما على للج او ۲6۳0۷6 . 


لا يقوم 6۷ل بتشغيل البرنامج على أي نوع طرفيه , ولا حتى يتم كتابة نص سكربت في داخل القاعده , يقوم فقط بتنفيذ البرامج 
التي تبدء في مقدمة الملف ب 

#!/bin/sh 
. وخلاف ذالك لا يقوم بتنفيذ أي شيء , كما انه أيضا لن يقوم بكتابة أي رساله في الطرفيه‎ 
البيئة التفاعلبه‎ 
, Assignment حıيتافم و‎ Na الذي يوفر البيئه تفاعليه التي يُمکن إستخدامها سواء مع مفاتیح‎ E۷ ۷ل توفر مفتاح‎ 


ی حالة ال Assignment‏ فیمكنك تعین متغیر تستفید منه فیما بعد مع مفاتیح Match‏ , كما أنه بامكانك إستخدام بيئة المتغيرات 
مع أحد البرامج التنفيذيه المذكوره سابقا بأسلوب معين معها , أنظر المتال التالي امعرفة طريقة إستخدام الغتاح ۷غ 


5 


KERNEL==“fd0” , SYMLINK+=“floppy” , ENV{some_ env}=VALUE” 


في حالة الد طء ع1 , بإمكانك أن تجعل القاعده تعتمد على متغير معين في بيئة المتغيرات , مع ملاحظة أنه يجب أن يكون 
المتغير متوفر في بيئة المتغيرات و يُمكن للمستخدم معرفة قيمته من خلال الد 1٥ء1٥‏ , تابع المثال التالي 


KERNEL==“fd0* , ENV{some_ env}==“yes” , SYMLINK+=“floppy” 


كأنك تستخدم قاعدة £ ز في البرمجه , و القاعده السابقه تقول أنه إذا توفر المتغير sone _ env‏ ویحمل قیمه ٥ر‏ قم بعمل 
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إختصار للجهاز 10ع في المجلد عل بأسم رمم ه۴1 
خیار ات اضافيه 


هناك مفتاح يُمكنك استخدامه غل حسب فكر تك الشخصيه المفتاح من نوع assignment‏ و أسنسة g OPTIONS‏ هذا 


لمفتاح يقبل ثلاث قيم فقط كتالي 

إنشاء كل الأقسام الممكن إنشائها في الد )ما8 هع أ۷ه, وليس فقط التي تم الكشف عنها عند الإقلاع all partions‏ 
تجاهل الحدث تماما ignore device‏ 
عدم تتفیذه لأي قو اعد أخرى last_rule‏ 


KERNEL==/sda”“, GROUP=“disk” , OPTIONS+=“last rule” 


USB Printer 


لنفرض أن لدينا طباعه , وقمنا بتوصه بالجهاز , فأنتج لدينا مسار 0م7/1٠ل/‏ , ونريد الأن تغير أسمه إلى أسم أكثر مدلوليه , 
سنقوم بالإعتماد على برنامج له 7ء هن الذي سيقوم بتزويدنا بالقواعد التي سنكتبها . 
udevadm info -a -p$ (udevadm info -q path -n /dev/lp0)‏ 
looking at device '/class/usb/lp0':‏ 
KERNEL=="1p0"‏ 
SUBSYSTEM=="usb"‏ 
DRIVER==""‏ 
ATTR{dev}=="180:0"‏ 


looking at parent device '/devices/pci0000:00/0000:00:1d.0/usb1/1-1': 
SUBSYSTEMS=="usb" 
ATTRS{manufacturer}=="EPSON" 
ATTRS{product}=="USB Printer" 
ATTRS{serial}=="1L72010011070626380" 


إذا ستكون القاعده كتالي : 


SUBSYSTEM=="usb", ATTRS{serial}=="1L72010011070626380", SYMLINK+="epson 680‏ 
لكي يكون أسم الجهاز بعد ذالك ومساره 680 _۸١0ءمء/evل/‏ 


USB Camera 


الكمرا الرقميه الخاصه بي ثعرف على أنها قرص خارجي عندما أقوم بتوصيلها في منفذ اد 58ل , و تستخدم |؟S©S؟S‏ 
اranspor)‏ , ويقوم النظام بضمها و أقوم أنا بأخذ الصور من الكميرا و أحفظها في المكان المخصص للصورعلى القرص 
الصلب الرئيسي , ولكن ليس كل الكميرات تعمل بهذه الطريقه , فبعض الكميرات الرقميه وخصوصا القديمه لا تقوم بإنشاء منفذ 
لقرص خارجي ولكن هناك مكتبه أسمها 02أه مو ط1ا أو 02ا0٣‏ من تقوم بعلاج هذه المشكله , وفي هذه الحاله لا يكون هناك 
أي حاجه إلى كتابة قواعد لهذا الكميرا . 

المشكله الرئيسيه مع الكميرات الرقميه أنها تقوم بإنشاء قرص خارجي واحد فقط ( أي ليس مقسم 1 و 2 و.. ) فمتلا إذا كان لدي 
لك و 1طلء فعند هذا 41ء افيد لي من طلء لأن 41ء هو الذي أريد ضمه فقط , و الأكثر من هذا أنه يُقيد إمكانيات 
۴6ء حيث أنه من المفيد لد ۷244۳ لن ان يقوم بتحديد المفاتيح المناسبه ل 1طلء التي ستكون قسم في ال5 , ولكن في 
حالتنا هذه ستكون النتيجه على إثنين أي القرص الرئيسي و الفرعي , وهذا الذي لا نريده , لذالك يجب أن تكون القاعده شيء 
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خاص جداً . 


و سيكون من المدهش إذا عرفت ما الفرق بين الأسمين ال5 و 61ل ... الفرق في الاسم فقط ( في حالة الكميرا) , أي أن 
بإمكانك استخدامها كمفتاح ٠ءأج"‏ و إنشاء 1طل0ء عن طريق المفتاح NAME‏ . و ببساطه سنقوم بكتابة التالي السا 
المطلوب . 


# udevadm info -a -p $( udevadm info -q path -n /dev/sdb1) 
looking at device '/block/sdb/sdb1': 
KERNEL=="sdb1" 
SUBSYSTEM=="plock" 


looking at parent device '/devices/pci0000:00/0000:00:02.1/usb1/1-1/1- 

1:1.0/host6/target6:0:0/6:0:0:0': 

KERNELS=="6:0:0:0" 

SUBSYSTEMS=="scsi" 

DRIVERS=="gsd" 

ATTRS{rev}=="1.00" 

ATTRS{model}=="X250, D560Z,C3502Z" 

ATTRS{vendor}=="OLYMPUS " 
ATTRS{scsi level}=="3' 
ATTRS{type}=="0" 


وسنكتب القاعده كتالي 


KERNEL=="sd?1", SUBSYSTEMS=="scsi", ATTRS {model}=="X250, D560Z,C3502", 
SYMLINK+="camera”" 


تفسير علامة (?) هو أننا لا نستطيع تحديد القاعده بأنها دائما ستكون طلء فإفترض وضعك لقرص خارجي 


USB Hard Disk 


مثل فكرة الكميرا هي نفس فكر ه القرص الصلب الخارجي ولكن من الممكن تقسيم القرص الصلب عن طريق الأمر )ءال بينما لا 
يمكن تقسيم الكميرا !! 


ولكن قاعده القرص الصلب الخارجي سهله جده و سنفترض الإحتمالين إذا كان مة مقسم إلى أكثر من قسم أم لا 


KERNEL=="sd*", SUBSYSTEMS=="scsi", ATTRS {model}=="USB 2.0 Storage Device", 
SYMLINK+="usbhd$%n" 


نتائج هذه القاعده ستکون کتالي 
/dev/usbhd‏ 


/dev/usbhd1 
/dev/usbhd2 
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بحت تعليمي 
USB Card Reader‏ 


هناك آنواع كثيره من أنواع قارة كروت الذاكره متٿل aأd Compact ۴اash, 5S" 2۲Me‏ و غيره الكثر و هي تعتبر أيضا من 


وسائل التخزين الخارجيه مثل غيرها . 


لكن نفرض أنك قمت بوضع جهاز القارء نفسه في الجهاز مع كرت ذاكره فسيكون هناك قسم و قسم فرعي أي الك و 01ء 
ولكن في حالة إنتزاع الذاكره فبذالك لن يكون هناك 1طلء لأن الجهاز لن يدرك هذا وهذا قد يُسبب بعض المشاكل خصوصا عند 
إضافه قرص خارجي أخر و الكارثه تكون عندما يكون القرص الخارجي هام .. فهناك فرصه للخطا كبيره من جهة المستخدم 
سرا في السح اى انيه أ غيره سن العمليات التي قد بب ققد المخرمات المامة , المشكله الأخرى وهن آنا ركن أن كرت 


الذاكره مقسم للعديد من الاقسام , فستكون الكارته أكبر و أكبر . 
ولکن لعلاج هذه المشكله سنستخدم في القاعد المفتاح OPTIONS‏ مع الخيار all_partions‏ وستكون القاعده کتالي 


="sd*", SUBSYSTEMS=="scsi", ATTRS{model}=="USB 2.0 CompactFlash Reader", 


Fl 


KERN 


SYMLINKt="cfrdrSn", OPTIONS+="all partitions" 


سیکون نتائج القاعده کتالي 


/dev/cfrdr, cfrdr1, cfrdr2, cfrdr3, ... 


Network Interface 


على الرغم من أن الشبكه لها أسم معروف إلى أنها لا تمتلك مله مء ا۷٥0‏ في مجلد ۷٥ل‏ , إلى أن كتابة قاعده لها أمر سهل 


تنفیذه 


كل ما سنحتاج إليه لتميز جهاز الإتصال بالشبكه هو الد ۸۸٥‏ حيث أنه رقم مُميز يُمكن الإعتماد عليه ولكن تأكد جيداً أنه مكتوب 


بصوره صحيحه في القاعده وإلى لن يقوم 46۷ل بتنفيذها . 


# udevadm info -a -p /sys/class/net/eth0 
looking at device '/class/net/eth0': 


HRNEL=="ethO0" 


BSYSTEM=="net" 

IVER=="" 

TR{addr_ len}=="6" 

TR{dev id}=="0x0" 

TR{ifalias}=="" 

TR{iflink}=="2" 

TR{ifindex}=="2" 
TR{features}=="0x180" 
TR{type}=="1” 

TR{link_ mode}=="0" 
TR{addFESS}==™OO:IOEESEISITTIA:CA™ 
TR{DEOAQACASL FSFE FETECIEESEETEE™ 
TR{carrier}=="1" 

TR{dormant }=="0" 
TR{operstate}=="up" 
TR{mtu}=="1500" 
TR{flags}=="0x1003" 
TR{tx_ queue_len}=="1000" 


kK 
SU 
DR 
AT 
AT 
AT 
AE 
AT 
AT 
AEE 
AE 
AE 
AT 
AT 
AT 
AT 
AT 
AT 
AT 


looking at parent device '/devices/pci0000:00/0000:00:1e.0/0000:05:00.0': 


ERNELS=="0000:05:00.0" 


BSYSTEMS=="pci" 
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DRIVERS=="r81 69" 
ATTRS{vendor}=="(0x10ec™" 
ATTRS{device}=="0x8169" 
ATTRS{subsystem vendor}=="0x1558" 
ATTRS{subsystem device}=="0x0660" 
ATTRS{class}=="0x020000" 
ATTRS{irq}=="18" 

ATTRS{local cpus}=="ff" 
ATIRS{Local. cEpulist ==" (0= ™ 
ATTRS{modalias}=="pci:v000010ECdO00008169sv00001558sd00000660bcO02sc00i100" 
ATTRS{broken parity _ status}=="0" 
ATTRS{msi_ bus }=="™™ 
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looking at parent device '/devices/pci0000:00/0000:00:1e.0': 
KERNELS=="0000:00:1e.0" 

SUBSYSTEMS=="pci" 

DRIVERS=="" 

ATTRS{vendor}=="0x808 6" 

ATTRS{device}=="0x2448" 

ATTRS{subsystem vendor}=="0x0000" 

ATTRS{subsystem device}=="0x0000" 

ATTRS{class}=="0x060401" 

ATTRS{irq}=="0" 

ATTRS{local cpus}=="ff" 

ATTRS{local cpulist}=="0-7" 

ATTRS{modalias}=="pci:v00008086d00002448sv00000000sd00000000bcO06sc04i101" 

ATTRS{broken parity status}=="0" 

ATTRS {ms i_bus ==" 1" 


looking at parent device '/devices/pci0000:00': 
KERNELS=="pci10000: 00" 
SUBSYSTEMS==" " 
DRIVERS=="™™ 


إذا نظرت على المخرجات جميعها أرقام غامضه ولكن الشيء الوحيد الذي يُمكن أن نثق فيه هو البيان ءو٠إ‏ لهج و بناء على 
هذا ستكون القاعده كتالي 


KERNEL==eth*”,ATTR{address}=="00:90:f5:53:9d:c2",NAME=”lan” 


ستحتاج إلى إعادة تشغيل الشبكه للحصول على النتائج الجديده , وبإمكانك أيضا إعادة تشغيل الوحدات التي تعمل مع الشبكه و 
الأفضل من كل هذا إعادة تشغيل النظام عن طريق المفتاح »5رك ( هناك شرح في مجتمع لينكس العربي ) , وقد تحتاج إلى 
تعدیل الإعدادات الخاص بالشبكه لإستبدال La îê tÊ‏ (من المستحسن تجربة تغير الإعدادات قبل إنشاء القاعده حيث أن هناك 
توزيعات ترفض التغير ) بعد هذا بإمكانك إستخدام الأسم الجديد في كل البرامج مثل و۴ ”هء] 1 و غيرها من البرامج بدلا من 
الأسم القديم . 
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تقوم ءل بإحضار ملفات القواعد و تشغيلها تلقائيا كل هذا بالإعتماد على جزء في النواه يُسمى y‏ ذا هد1 , أي أنه إذا قمت 
ملا بإنشاء إختصار N۸‏ 5۲11,1 للكمیرا , فسیقوم 7٥ل‏ ں بالتعرف على التغير الجديد بمجرد فصل الكميرا و توصيلها مره 
أخرى , أو بإمكان بدلا من هذا كتابة الأمر التالي بدلا من الفصل و التوصيل للجهاز 


udevadm trigger 


أما إذا كانت النواه لا تدعم رع 1٤0د‏ 1 فلن يقوم عل ن بضم القواعد الجديده تلقائيا , وفي هذه الحاله ستقوم بكتابة الأمر التالي 
بعد کتابة کل قاعده جدیده و بعد کل تعدیل على قاعده سابقه 


udevadm control --reload rules 


إذا كنت تعرف الفرع الرئيسي ( ام۷ها-مه٠‏ ) لمسار جهاز ما في ال ورو , فبإمكانك إستخدام الأمر udevadm test‏ 
لمعرفة الأحداث الذي يقوم بها ۷هلں مع هذا الجهاز , هذا الطريقه تساعدك كثيراً في تنقيح قواعدك التي تكتبها , على إفتراض 
أك ريد الكشف على الجهاز الذي في المسار التالي معل/Q"دهكء/ءءهاء/ورء/‏ فسيكون الأمر كتالي 


$ udevadm test /sys/class/sound/dsp 
run_ command: calling: test 


udevadm test: version 141 

This program is for debugging only, it does not run any program, 

specified by a RUN key. It may show incorrect results, because 

some values may be different, or not available at a simulation run. 

parse File: £eading '/êtce/udev/Fûlés,.d/10-Yboxdrv.EULes' a8 rules File 

parsê file: reading '/lib/udev/rüles.d/40-alsa.sules' as rules file 

parsê file: reading '/LiB/uûdev/rules.d/40-khplip.rules" as süles filê 

parse_file: reading '/lib/udev/rules.d/40-ia64.rules' as rules file 

parsê Filê: feading 'Zlib/udev/fûlêés<d4/40-infiniband.fules" aãsé Fulêéês TFil؛é‎ 
parse_file: reading '/lib/udev/rules.d/40-isdn.rules' as rules file 

parse file: reading '/Lib/üdev/ruüles,d/40-LlibpisockI.tules'" as rules File 

parse filê: reading '/lib/udev/rules.d/40-pilot-links.rüles' as rules File 

parse Filê: feading. 'Zlib/udev/Fûlé8.d/40-ppe.FULes" as rules Tile 

parse_file: reading '/lib/udev/rules.d/40-xserver-xorg-input-wacom.rules' as 
rules file 

parse file: reading '/lib/udev/rüles.d/40-zaptel.rules" as rtüleês File 

parse file: reading '/lib/udev/rules.d/45-füuse.rcules' as rules file 

parse File: feading 'ZlLib/udev/FULlê68d4/45-LiBmMEBE.FULes"' a46 fulês file 
parse_file: reading '/lib/udev/rules.d/50-firmware.rules' as rules file 

parêe file: reading '/Lib/udev/rülês.d/50-üdev-default;rüles' ã8 rûles file 
parse_file: reading '/lib/udev/rules.d/60-cdrom id.rules' as rules file 

parse file: £éading 'Zlib/udev/fulês.d/60-persistent=inpüûlt.tûles' as rules Tile 
parsê filê: reading '/lib/udev/rüiles.d/60-persistent-serial.rules' as rûles file 
parsê file: reading '/libB/ûdev/rules.d/60-pêerslstent-storage=tape. FUles' as rules 
file 

parsê file: feading 'ZlLib/uüdev/rulés.d/60-persistent-storage, rules" as rûles File 
parse file: reading '/lib/udev/rüles.d/60-persistent-v41l. rules" as rüles file 
parse fFilé;: reading '/lib/udev/rüles.d/61-option-modem=-modeswiteh.Fuûles" as fuûles 
file 

parse filê: reading '/lib/udev/rules.d/61-persistent-storage-edd.rules' as rules 
file 

parsêé Fille: reading '/Lib/udev/süles.d/62-blLluéez-hid2hei.tules' ã8 rules file 
parse file: reading '/lib/udev/rüles,.d/64-devicée-mapper.rüles" ãs Fülêes file 
parse file: reading '/lib/udev/rules.d/65-dmsetüp.rules' as rules file 
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parsê filê: Eeading '/lib/ûdev/rales 4/70-aCl,Fules" a8 Biles file 

patse file: reading '/ete/üidev/rules.d/T0-persistent-cd, rules" aãs zules Filê 
parsê file; reading '/etc/üdev/rules:d/70-persistent=-net.rules' as rûles file 
parse file: reading '/1i1b/udev/rules.d/75-cd-aliases-generator.rules' as rules 
file 

parse file: reading '/lib/üdev/rules.d/75-persistent-net-generator.tüules'" as 
rules file 

parse file: reading '/1lib/udev/rules.d/771-im-probe-modem-capabilities. rules" as 
rules file 

parsê filê: feading 'Zlib/üdev/rales .4/77-probe-modem-capabilitiés,. rules" a8 
rules file 

parsê file: reading '/lib/üdev/ruüles:d/79-fstab import.rules'" as rüles file 
parse file: reading '/1ib/udev/rules.d/80-=dsivers.tûles' as rules file 

parsê file: feading 'ZlLib/udev/ruüles <;4/85-alsa-ulils.tûles' as rtules File 
parse_file: reading '/lib/udev/rules.d/85-brltty.rules' as rules file 

parsê file: reading '/lib/udev/rules.d/8§85-hdparm.rules' as rüles file 
parse_file: reading '/lib/udev/rules.d/85-hplj10xx.rules' as rules file 

parsê File: Eeading 'Zlib/udev/ruûles<4/85-hwcelock.Eules" as füles file 

parse file: reading '/Lib/üdev/rules.d/85-i1fupdown. rules" as rüles filê 

parse file: reading '/lib/uüdev/rules:d/85-penmcia:rules' a8 rüûles file 

parse file: reading '/l1ib/üdev/rules.d/85-regulatory.trüles' as rûles filê 
partse file: reading '/ete/udev/rules.d/9-myrules.tules' as rules file 

parsê. files feading 'ZLiIbBVUQdEV/TULeS.4/90=khalsrules" aãs ules file 

patse file: reading '/etce/udev/rules.d/95-calibrse.tules' a8 rules file 

parsê file: reading '/lib/udev/rules,d/95-=-üdev-late., tüles' as rüles file 
udev_rules_new: rules use 49272 bytes tokens (4106 * 12 bytes), 14436 bytes 
buffer 

udev_rules_ new: temporary index used 20040 bytes (1002 * 20 bytes) 

udev device new from syspath: device QxbTfde9a0 has devpath '/class/soünd/dspþ' 
udev device new from syspath: device Oxb7fdeb20 has devpath '/class/sound/dsp' 
udev_ device_read db: device O0xb7fdeb20 filled with db file data 

udev rules apply to event: GROUP 29 /lib/udev/rules.d/40-alsa.rules:3 

udev_ device_new from syspath: device Oxb7fdee40 has devpath 
'/devices/pci0000:00/0000:00:1b.0'" 

udev device new from syspath: device OxbTfdf0a0 has devpath '/devices/pci0000:00' 
udev rules apply to event: LINK 'char/14:3' /lib/udev/rules.d/50-udev- 
default.rules:5 

udev _rüles apply to _ event: RUN 'socket:€/org/freedesktop/hal/udev_ event' 


kernel name 'dsp'" 
ssion denied 
devnum=14: 3, mode=0660, uid=0, 


Permi 


W/dSp", because {Î has Gortect dev € 


dsp' has the highest priority 0, 


'/dêv/ehar/14:3" t6 "../ASp" 


'/dev/ 


sting symlink 
'socket:€/org/freedesktop/hal/udev_ event" 


target 


/90-hal.rules:2 


_ rules: no node name set, will us 
unable to create db file 
fsound\x2fdsp' : 
'/dev/dsp'", 


e_db: 
2ECLASSNX2 
eating devic 


nod 


'/d 
with 


Fil 


serve already exi 


udev_node_mknod: preserv 
'/dev/char/14:3' 


EIU 


/1ib/udev/rules.d 
udev_ event _execut 
udev_ device _updat 
'/dev/.udev/db/\x 
udev_node_ add: cr 
gid=29 


update_link: 
create it 
node_ symlink: pr 
udevadm test: 


كما هو واضح , المكتبات التي يتعامل معها جهاز مكل و الأجهزه التي يعتمد عليها أيضا , بإمكانك عن طريق القراءه المُتأنيه 


للمخرجات الحصول على نتائج مُرضيه لقواعدك . 


صفحة 21 
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* 


FH 
8 الخاتمه‎ 
E ااا‎ 


بهذا قد تم الإنتهاء من البحث النعليمي هذا و أدعو الله أن يكون قد وفقني في تغطية أكبر كم ممكن من طرق التعامل مع ال اعل ل 
و على أمل من الله اني أكون قد قمت بتوعية أخوتي العرب من مخاطر الوقوع في لبس أسماء الأجهزه و تقديم حلول لعدم الوقوع 
في هذا الخطا الذي فد ادي إلى خسار ة الكثير من المعلومات الهامه : 


وفي النهايه أتمنى من كل من قراء هذا البحث آن يقوم بنشره أكثر فأكثر حتى تعم الفائده علينا جميعا و إذا أمكن الإضافه على 
معلوماته فأکون شاکر له بعد الله 
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